# TPU Instruction Set Architecture v1.5

Revision 5

May 1st 2016

Domipheus Labs

http://labs.domipheus.com

## **Contents**

| Version History                                          | 4  |
|----------------------------------------------------------|----|
| Known Issues                                             | 5  |
| Arithmetic does not set correct overflow status flags    | 5  |
| Latencies                                                | 5  |
| Interrupt model in flux                                  | 5  |
| Endianness                                               | 5  |
| Glossary                                                 | 5  |
| Instruction Forms                                        | 6  |
| Definitions                                              | 6  |
| Layout                                                   | 6  |
| Instruction Listing                                      | 7  |
| add.s, add.u                                             | 7  |
| addi.u                                                   | 7  |
| sub.s, sub.u                                             | 7  |
| subi.u                                                   | 7  |
| or                                                       | 9  |
| xor                                                      | 9  |
| and                                                      | 9  |
| not                                                      | 9  |
| read, read.w, read.b                                     | 10 |
| write, write.w, write.b                                  | 10 |
| load.h, load.l                                           | 10 |
| cmp.s, cmp.u                                             | 11 |
| shl                                                      | 12 |
| shr                                                      | 12 |
| br                                                       | 13 |
| biro                                                     | 13 |
| br.eq, br.az, br.bz, br.anz, br.bnz, br.gt, br.lt        | 13 |
| bro.eq, bro.az, bro.bz, bro.anz, bro.bnz, bro.gt, bro.lt | 14 |
| spc                                                      | 14 |
| sstatus                                                  | 14 |
| gief                                                     | 15 |

| bbi |    |
|-----|----|
| ei  | 15 |
| CI  | ±3 |
| di  | 15 |
| int | 16 |

## **Version History**

| Version | Description                                                                                                                                                                              | Date                            |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| 1.0     | Initial                                                                                                                                                                                  |                                 |
| 1.1     | Added Save PC, Save Status, add immediate unsigned, sub immediate unsigned, Jump conditional to relative offset                                                                          | July 31 2015                    |
| 1.2     | References to jumps replaced with branches. Branch conditionals with new instruction forms. Read and Write now have a signed offset in the encoding.                                     | August 3 2015                   |
| 1.3     | Byte addressing modes for read/write & endianness                                                                                                                                        | September 21 <sup>st</sup> 2015 |
| 1.4     | Exception handling model and instructions                                                                                                                                                | October 1 <sup>st</sup> 2015    |
| 1.5     | INT instruction, fixing of flag0 bit of add and sub instructions from reserved to fixed 0.  Branch immediate was removed, in it's place we now have branch to immediate relative offset. | May 1 <sup>st</sup> 20016       |

#### **Known Issues**

#### Arithmetic does not set correct overflow status flags

The Addition and Subtraction instructions, of signed variants, do not correctly set overflow flags.

#### Latencies

Latencies are not fully known until CPU design is finalized; however, all instructions apart from memory read and write take a fixed amount of cycles. Memory read and write add additional latencies.

## Interrupt model in flux

Currently, interrupts can automatically disable on hit, but this is not fully exposed/documented yet.

TPU is not pipelined.

Each instruction takes at minimum 7 clock cycles.

#### **Endianness**

TPU is currently big endian. 16 bit values are stored from bit 15 to bit 0 as MSB to LSB high byte to low byte.

When reading/writing 16-bit words to and from memory, the most significant byte will be written to the smaller address, the least significant byte written to address+1.

## **Glossary**

| Ор  | Op Code              |
|-----|----------------------|
| Rd  | Destination Register |
| F   | Function flags       |
| Ra  | Source Register A    |
| Rb  | Source Register B    |
| lmm | Immediate Value      |
| Fs  | Signed Flag          |
| R   | Reserved             |
| Х   | Undefined            |
| С   | Conditiona flags     |

#### **Instruction Forms**

#### **Definitions**

- Form RRR
  - o Destination and two source registers
- Form RRs
  - o Two source registers, optional immediate
- Form RRd
  - o One destination and one source register, optional immediate
- Form CRsI
  - o Ass RRd, however, rD is used as a constant flag section.
- Form CRR
  - Condition flags and two source registers
- Form R
  - o A single source register
- Form RRImm
  - o Destination, Source and 4-bit immediate.
- Form RImm
  - o Destination register with 8-bit immediate value
- Form Imm
  - o 8-bit immediate value, can optionally use [11:9] to extend the immediate.
- Form RRImm
  - o Destination reg, source reg and 4-bit immediate

All forms have various flag and unused bit spaces that instruction operations may use.

## Layout

|      | 15     | 14  | 13  | 12 | 11           | 10     | 9  | 8 | 7                       | 6  | 5   | 4      | 3      | 2       | 1     | 0       |
|------|--------|-----|-----|----|--------------|--------|----|---|-------------------------|----|-----|--------|--------|---------|-------|---------|
| RRR  |        | орс | ode |    |              | rD     |    | F |                         | rA |     |        | rB     |         | L     | Inused  |
| RRs  |        | орс | ode |    | Im           | nm[4:2 | 2] | F |                         | rA |     |        | rB     |         | In    | nm[1:0] |
| RRd  |        | орс | ode |    |              | rD     |    | F |                         | rA |     |        | 5-k    | oit imi | nedia | ate     |
| CRsI |        | орс | ode |    |              | С      |    | F |                         | rA |     |        | 5-k    | oit imi | nedia | ate     |
| CRR  | opcode |     |     |    |              | С      |    | F |                         | rA |     |        | rB     |         | ι     | Jnused  |
| RRIm | opcode |     |     |    |              | rD     |    | F |                         | rA |     | 4-k    | oit Im | media   | ate   | ?       |
| m    | Орсоце |     |     |    |              |        |    |   |                         |    |     |        |        |         |       |         |
| R    |        | opc | ode |    |              | rD     |    | F | Unused                  |    |     |        |        |         |       |         |
| RImm | opcode |     |     |    | rD           |        |    | F | F 8-bit Immediate Value |    |     |        |        |         |       |         |
| lmm  | opcode |     |     |    | Optional Imm |        |    | F |                         |    | 8-b | it lmr | nedia  | te Val  | ue    |         |
|      |        |     |     |    |              |        |    |   |                         |    |     |        |        |         |       |         |

## **Instruction Listing**

#### add.s, add.u

Add signed or unsigned

Instruction Form RRR

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
|----|----|----|----|----|----|----|---|----|----|----|----|----|----|---|---|
| 0  | 0  | 0  | 0  | Rd | Rd | Rd | S | Ra | Ra | Ra | Rb | Rb | Rb | R | 0 |

Regs[Rd] = Regs[Ra] + Regs[Rb]

The bit S indicates whether the addition operation is signed. If S is 1, the operands are taken as signed integer values, unsigned otherwise.

#### addi.u

Add unsigned immediate

Instruction Form RRImm

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6  | 5  | 4   | 3   | 2   | 1   | 0 |
|----|----|----|----|----|----|----|---|----|----|----|-----|-----|-----|-----|---|
| 0  | 0  | 0  | 0  | Rd | Rd | Rd | 0 | Ra | Ra | Ra | lmm | Imm | lmm | Imm | 1 |

Regs[Rd] = Regs[Ra] + Imm

#### sub.s, sub.u

Subtract signed or unsigned

Instruction Form RRR

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
|----|----|----|----|----|----|----|---|----|----|----|----|----|----|---|---|
| 0  | 0  | 0  | 1  | Rd | Rd | Rd | 0 | Ra | Ra | Ra | Rb | Rb | Rb | R | 0 |

Regs[Rd] = Regs[Ra] - Regs[Rb]

The bit S indicates whether the addition operation is signed. If S is 1, the operands are taken as signed integer values, unsigned otherwise.

#### subi.u

Add unsigned immediate

Instruction Form RRImm

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

| Ì | 0 | 0 | 0   | 1 | Rd | Rd | Rd | 0   | Ra | Ra | Ra | Imm | Imm | Imm | Imm | 1 |   |
|---|---|---|-----|---|----|----|----|-----|----|----|----|-----|-----|-----|-----|---|---|
|   | • |   | . • | _ |    |    |    | . • |    |    |    |     |     |     |     | _ | 1 |

Regs[Rd] = Regs[Ra] - Imm

#### or

Bitwise OR

Instruction Form RRR

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
|----|----|----|----|----|----|----|---|----|----|----|----|----|----|---|---|
| 0  | 0  | 1  | 0  | Rd | Rd | Rd | 0 | Ra | Ra | Ra | Rb | Rb | Rb | R | R |

Regs[Rd] = Regs[Ra] or Regs[Rb]

#### xor

Bitwise XOR

Instruction Form RRR

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
|----|----|----|----|----|----|----|---|----|----|----|----|----|----|---|---|
| 0  | 0  | 1  | 1  | Rd | Rd | Rd | 0 | Ra | Ra | Ra | Rb | Rb | Rb | R | R |

Regs[Rd] = Regs[Ra] xor Regs[Rb]

#### and

Bitwise AND

Instruction Form RRR

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
|----|----|----|----|----|----|----|---|----|----|----|----|----|----|---|---|
| 0  | 1  | 0  | 0  | Rd | Rd | Rd | 0 | Ra | Ra | Ra | Rb | Rb | Rb | R | R |

Regs[Rd] = Regs[Ra] and Regs[Rb]

#### not

Bitwise NOT

Instruction Form RRd

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6  | 5  | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---|----|----|----|---|---|---|---|---|
| 0  | 1  | 0  | 1  | Rd | Rd | Rd | 0 | Ra | Ra | Ra | 0 | 0 | 0 | R | R |

Regs[Rd] = not Regs[Ra]

## read, read.w, read.b

Memory Read

Instruction Form RRd

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6  | 5  | 4 | 3 | 2   | 1 | 0 |
|----|----|----|----|----|----|----|---|----|----|----|---|---|-----|---|---|
| 0  | 1  | 1  | 0  | Rd | Rd | Rd | В | Ra | Ra | Ra |   |   | Imm |   |   |

Regs[Rd] = Memory[ Regs[Ra] + Imm ]

Reads a value from memory at the specified location into the destination register. When B=1, a byte is read. If B=0, a 16-bit value is read. Byte addressing applies throughout.

The Immediate offset is considered a signed value.

#### write, write.w, write.b

**Memory Write** 

Instruction Form RRsW

| 15 | 14 | 13 | 12 | 11  | 10  | 9  | 8 | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0  |
|----|----|----|----|-----|-----|----|---|----|----|----|----|----|----|-----|----|
| 0  | 1  | 1  | 1  | Imm | Imm | lm | В | Ra | Ra | Ra | Rb | Rb | Rb | Imm | lm |
|    |    |    |    |     |     | m  |   |    |    |    |    |    |    |     | m  |

Memory[ Regs[Ra] + Imm ] = Regs[Rb]

Writes the value in Rb into memory at the specified location. When B=1, a byte is written (lower half of register Rb). If B=0, a 16-bit value is written. Byte addressing applies throughout.

The Immediate offset is considered a signed value.

#### load.h, load.l

Load Immediate High, Load Immediate Low

**Instruction Form RImm** 

| 15 | 1 | 4 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 1  | ( | ) | 0  | 0  | Rd | Rd | Rd | LF | lm | lm | lm | lm | Im | lm | lm | lm |

If LF = 1 then

Regs[Rd] = 0x00FF & Im

else

Regs[Rd] = 0xFF00 & Im << 8

End if

#### cmp.s, cmp.u

**Compare Integers** 

Instruction Form RRR

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6  | 5 | 4 | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|---|----|---|----|---|---|----|---|---|---|
| 1  | 0  | 0  | 1  |    | Rd |   | Fs |   | Ra |   |   | Rb |   | R | R |

Regs[Rd] = compare (Regs[Ra], Regs[Rb], Fs)

Compares integer values within registers *Ra* and *Rb*, placing a result bit field in *Rd*.

If *Fs* is set, comparisons are treated as signed integers. The result bit field written to *Rd* is defined as follows. The result of the comparison goes into the associated bit of the register, a set bit indicating true.

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Х  | Ra | Ra | Ra | Ra | Rb | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х |
|    | =  | >  | <  | =  | =  |   |   |   |   |   |   |   |   |   |   |
|    | Rb | Rb | Rb | 0  | 0  |   |   |   |   |   |   |   |   |   |   |

## shl

Shift Left Logical from Register

Instruction Form RRR

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
|----|----|----|----|----|----|----|---|----|----|----|----|----|----|---|---|
| 1  | 0  | 1  | 0  | Rd | Rd | Rd | 0 | Ra | Ra | Ra | Rb | Rb | Rb | R | R |

Regs[Rd] = Regs[Ra] << Regs[Rb]

## shr

Shift Right Logical from Register

Instruction Form RRR

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
|----|----|----|----|----|----|----|---|----|----|----|----|----|----|---|---|
| 1  | 0  | 1  | 1  | Rd | Rd | Rd | 0 | Ra | Ra | Ra | Rb | Rb | Rb | R | R |

Regs[Rd] = Regs[Ra] >> Regs[Rb]

#### br

branch to register location

Instruction Form RRR

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6  | 5  | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|----|----|----|---|---|---|---|---|
| 1  | 1  | 0  | 0  | 0  | 0  | 0 | 0 | Ra | Ra | Ra | 0 | 0 | 0 | R | R |

PC = Regs[Ra]

#### biro

Branch to immediate relative offset

Instruction Form Imm

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|---|----|----|----|----|----|----|----|----|
| 1  | 1  | 0  | 0  | lm | lm | lm | 1 | lm |

Immediate value is treated as signed.

PC = PC + (Im << 1);

## br.eq, br.az, br.bz, br.anz, br.bnz, br.gt, br.lt

**Branch Conditional** 

Instruction Form CRR

| 15 | 14 | 13 | 12 | 11             | 10    | 9  | 8 | 7 | 6  | 5 | 4 | 3  | 2 | 1 | 0 |
|----|----|----|----|----------------|-------|----|---|---|----|---|---|----|---|---|---|
| 1  | 1  | 0  | 1  | C <sub>2</sub> | $C_1$ | Co | 0 |   | Ra |   |   | Rb |   | 0 | 0 |

If **C** matches with condition bits written by a CMP instruction stored in Reg[**Ra**] then

PC = Reg[Rb]

Table of **C** bits to condition mappings.

| $C_2$ , $C_1$ , $C_0$ | Condition |
|-----------------------|-----------|
| 0, 0, 0               | EQ        |
| 0, 0, 1               | Ra = 0    |
| 0, 1, 0               | Rb = 0    |
| 0, 1, 1               | Ra != 0   |
| 1, 0, 0               | Rb != 0   |
| 1, 0, 1               | Ra > Rb   |
| 1, 1, 0               | Ra < Rb   |

## bro.eq, bro.az, bro.bz, bro.anz, bro.bnz, bro.gt, bro.lt

Branch conditional to relative offset

Instruction Form CRsI

| 15 | 14 | 13 | 12 | 11             | 10             | 9  | 8 | 7 | 6  | 5 | 4    | 3    | 2                | 1                | 0                |
|----|----|----|----|----------------|----------------|----|---|---|----|---|------|------|------------------|------------------|------------------|
| 1  | 1  | 0  | 1  | C <sub>2</sub> | C <sub>1</sub> | Co | 1 |   | Ra |   | lmm₄ | lmm₃ | Imm <sub>2</sub> | Imm <sub>1</sub> | Imm <sub>0</sub> |

Imm is signed.

If  ${\bf C}$  matches with condition bits written by a CMP instruction stored in Reg[ ${\bf Ra}$ ] then

PC = PC + Imm

Table of **C** bits to condition mappings.

| $C_2$ , $C_1$ , $C_0$ | Condition |
|-----------------------|-----------|
| 0, 0, 0               | EQ        |
| 0, 0, 1               | Ra = 0    |
| 0, 1, 0               | Rb = 0    |
| 0, 1, 1               | Ra != 0   |
| 1, 0, 0               | Rb != 0   |
| 1, 0, 1               | Ra > Rb   |
| 1, 1, 0               | Ra < Rb   |

#### spc

Save PC

Instruction Form RRR

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 0  | Rd | Rd | Rd | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |

Regs[Rd] = PC

#### sstatus

Save Status

Instruction Form RRR

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 0  | Rd | Rd | Rd | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
|    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |

Regs[Rd] = Status

## gief

Get Interrupt Event Field

Instruction Form RRR

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 0  | Rd | Rd | Rd | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |

Regs[Rd] = Interrupt Data Register Contents

#### bbi

Branch back from Interrupt

Instruction Form RRR

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 0  | 0  | 0  | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
|    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

Branches to the PC which was to be executed next before the last interrupt was encountered.

#### ei

Enable Interrupt

Instruction Form RRR

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 0  | Rd | Rd | Rd | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |
|    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |

#### di

Disable Interrupt

Instruction Form RRR

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 0  | Rd | Rd | Rd | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |
|    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |

#### int

Fire Interrupt programatically

Instruction Form Imm

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6   | 5   | 4   | 3   | 2   | 1 | 0 |
|----|----|----|----|----|----|---|---|-----|-----|-----|-----|-----|-----|---|---|
| 1  | 1  | 1  | 0  | 0  | 0  | 0 | 0 | Imm | Imm | Imm | Imm | lmm | lmm | 1 | 0 |
|    |    |    |    |    |    |   |   |     |     |     |     |     |     |   |   |

Saves the current PC+2 value for use in the bbi instruction, loads the Interrupt Event Field with the immediate value in [7:2], and branches to the interrupt vector.

Due to this, it is advised that Interrupt handlers treat Interrupt Event Field values of 0-63U as software interrupts, that can be invoked from user code.

The interrupt handler will be called, regardless of interrupts being enabled or not. Upon an int instruction execute, interrupts will be automatically disabled.